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Abstract 


Turing machines(TMs) are mathematical models of computation 
that define abstract machines. Because of their simplicity and consis- 
tency, they are amenable to mathematical analysis. These hypothetical 
machines are intended to help explore the concept of what it meant to 
be computable. These models form the foundation of theoretical com- 
puter science. A lot of theoretical computer science has been beard 
on TMs, and so a lot of the primary results are in the language of 
Turing machines. It's essential for computer science students to build 
up a strong foundation of computer science by understanding theoreti- 
cal models behind this field. Nowadays, Universities provide computer 
science education usually offers one or two classes to introduce Turing 
Machine. However, studying Turing Machine without a useful visual 
tool can be a little bit less intuitive. In this thesis, a Turing Machine 
simulator was created. Also, a universal Turing machine was proposed 
to show how a simulator works at a lower level. 
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1 Introduction 


1.1 Motivation 


Turing machines are hypothetical machines which were created by Alan Tur- 
ing in 1936 to explore the concept of what it meant to be computable[4]. A 
typical Turing Machine has an infinitely long stripe of tape composed of a 
number of squares with symbols written on them. These squares are used 
to store inputs and outputs computations for this machine. It also has a 
head that can read symbols from the squares, write symbols to the squares, 
and move left and right. It also has a set of transition functions which is 
essentially a program to tell Turing Machine what tasks to perform based 
on the machine's state and the read symbol. Every Turing Machine has an 
initial state and a halt state. A Turing Machine starts its computations from 
the initial state and finishes its task when it enters a halt state. Without a 
halt state, a turing machine will never terminate. 


Turing Machine is a foundation of modern computer programming. It 
is very important for computer science students to understand this comput- 
ing model to build up a strong foundation of their knowledge for computer 
science. Those popular programming languages and technical frameworks 
for practical use today will eventually be replaced by new technologies. In- 
stead,the theory behind computer programming has a long-lasting value, 
making people think about what problems can be solved and how can they be 
addressed effectively. As for its importance, universities take “Computability” 
Theory (this course may be called as “Format Language and Automata”)as 
a required class for computer science majors. Exposure to Turing Machine, 
students can get a general idea of what a computing model can do. However, 
statically presenting Turing Machine might be less intuitive. Some difficulties 
may occur in the learning process. First, how should an instructor explain 
the process from a Turing Machine starts until it terminates? It may need 
to draw a giant table to show all transition functions and an extremely long 
turing machine tape and walk students through this process by writing and 
erasing a massive amount of symbols. If the instructor would like to show 
students the different outputs of a Turing Machine given by various inputs, 
that's an enormous burden on the instructor's shoulder. Second, what if a 
student designs a Turing Machine and then wants to test it with some in- 
puts? He/She needs to check his/her transition table back and forth, while 


simulating the turing machine computing process, and it's very easy to make 
a mistake. Also, this procedure is a little bit longer, and the student might 
lose his focus on where his work is on, and then starts from the very begin- 
ning again. An Turing Machine Simulator can be a beneficial visual aid for 
this topic. Instructors no longer have to work on drawing Turing Machine on 
a whiteboard, instead focus on explaining what is happening on the machine. 
Also, if they want to switch Turing Machines, it can be done by just a few 
clicks. 

A Universal Turing machine (UTM) is a Turing Machine(TM) that can simu- 
late another Turing Machine based on its encoded description and its input. 
Some ideas in computer science such as compiler, interpreter are inspired 
by UTM. Designing a Universal Turing Machine is essentially creating a 
language. Like Micheal Soltys states in his book, "every computer science 
students should do this exercise "[13]. This is very helpful to students to 
gain knowledge of what a language is and what requirements are for a lan- 
guage. However, textbooks used in computability theory class either don't 
mention Universal Turing Machine|15], or lacking explantion for designing a 
UTM[11]. A Turing Machine simulator is essentially doing the same work as 
a UTM, but it hides the detail of how UTM works. In this thesis, a Univer- 
sal Turing Machine is created to reveal how a Turing Machine can simulate 
another Turing Machine and how a Universal Turing Machine can simulate 
all Turing Machines. 


2 Background 


In 1920, David Hilbert proposed a project now known as Hilbert's program|2]. 
He asked for a complete logical foundation to formulate mathematics. In 
1928, he introduced Entscheidungsproblem for this purpose|1]. This problem 
asks for an algorithm that takes an axiomatic formal system and a logical 
statement in that system as input, and the algorithm outputs true or false 
depending on the value of that statement. He believed that every problem 
is solvable. 

However, a lot of mathematicians gave their negative answers to entschei- 
dungsproblem. In the 1930s, GÓdel presented a complete axiomatic sys- 
tem based on first-order logic in his Ph.D. paper[7]. In this paper, GOdel 
proved his Completeness Theorem, and it states that for any self-consistent 
axiomatic system, it must contain theorem that cannot be proven. To prove 
this statement, Gódel developed a technique now known as Gódel numbering, 
which can code any formal expression as a single natural number. In 1933, 
Kurt GÓdel, with Jacques Herbrand, gave a formal definition of his axiomatic 
system called general recursive functions|8]. General recursive functions are 
a class of functions built from basic functions with composition, recursion, 
and minimization operators. 

In 1936, Church also proved that entscheidungsproblem is unsolvable by 
his model of computability of À — calclus. Within and by A — calculus, 
there is no effective way to determine whether a A term has a norm form. 
Alan Turing introduced Turing Machines|16] in the same year. He proved 
that entscheidungsproblem is unsolvable by presenting the Halting Problem. 
Halting Problem is asking whether a program A that takes a description of 
an arbitrary program B and B's input as its own input can determine pro- 
gram B is able to finish its computations or run forever. 


There is an extensive research about computability for mathematical 
problems. The basic research objects in this field are computable functions. 
In the notation of an algorithm, if there is an algorithm that can get the 
same job done for a function, then this function is computable. Formally, a 
function f : N* > N is computable => 3 Algorithm A for z € N^ yields y 
and f(z) = y [6]. 

A lot of mathematicians from around the world gave their own opin- 
ions about what is a computable function. Kurt GOdel described Recursive 


functions|8|, Alonzo Church defined the Lambda calculus[5], Stephen Kleene 
introduced Formal systems|10], Alan Turing described imaginary comput- 
ing device as Turing Machines, Emil Post defined Post machines|14], And 
Markov defined what became known as Markov algorithms [12]. Compu- 
tation functions are used to discuss computability without referencing any 
models above. When it comes to any definition, however, it must refer to 
some specific model of computation. As a function in Turing Machine, it 
is computable if only if it is computable in À — Calculus, and similarly for 
any other pairs of the above formal languages. Church expressed the belief 
that the intuitive notion of “computable” is identical to the above models’ 
concept. This belief is called “Church-Turing Thesis” which is universally 
accepted by mathematicians. 


2.1 General Recursive Function 


In mathematical logic and computer science, the general recursive functions 
are a class of partial functions that take a series of natural numbers as input 
and yield a natural number as output. They are functions that are build from 
basic functions by composition, primitive recursion, minimisation operators. 
It is shown that the general recursive functions compute the the same class 
of functions as by Turing Machines|3]. 


Basic functions: 


1. Constant function: A function takes a tuple of number as input, and 
awalys yields the same value, which is given by 


Οµίαι, aux) = n. 
where n and k are natural numbers 


2. Successor function S: A function take a natural number z as input, 
and yields z + 1, which is given by 


Sa) r-1 


3. Projection function P^: A function takes a tpule of number as in- 


put, and gives the value on certain position as output, which is given 
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by d.e: 
PF (zy, se. Ba ay 
where 1 and k are natural numbers andi > k 
Operators: 


1. Composition operator o: Given a m-place function h(x), ..., Tm) and 
m-place functions gi(z1, ..., Tk),..., gm (21, ..., Tk): 


ho(gi, ...θηι) zx f where ων Zk) = Gi Pixs; Zk), s Dm Pigs Bey) 


2. Primitive recursion operator p: Given a (k + 1)-place function 
g(21,..., £k) and (k + 2)-place function h(y, z, £1, ..., Zk): 


p(g, h) = f where the (k + 1)-place function f is defined by 
f (0,24, Ey) = g(X1, "Uy 
(y + 1, Tı, exe) = h(y, f(y, X15 Zk); Lio... Lk) 
3. Minimization operator u: Given a (k + 1)-place total function 


f (y, 1, ..., Tx), the k-place function u(f) is defined by: 


Bl) ep og = Z —— f(z,24,..., Zk) = Ü 


and f(i, £i, ..., £k) > 0 Tor i = 0,...,z — 1 
minimization seeks that smallet z that meets f(z, £1,..., £k) = 0, if this 
z doesn't exist, search will never terminate. 


Example 


e The predecessor function Pred:N — N, is a partial recursive function, 
defined by the recusion pred(0) = 0, Pred(S(n)) = P?(n, Pred(n)) 


e Truncated subtraction, where x+y = x — y if x > y, else 0. It is 
defined by the recursion z—0 = 2, x—(y + 1) = Pred(z—y) 


2.2 Lambda Calculus 


The lambda calculus is older than Turing's machine model, apparently dating 
from the period 1928-1929[9], and was invented to encapsulate the notion of 
a schematic function that Church needed for a foundational logic he devised. 


Definition Lambda calculus consists of constructing lambda terms and 
performing reduction operations on them. Lambda terms are defined recur- 
sively, t is a À term when it meets one of the following requirements|9], 


l. t=x, x is a variable 

2. t = Ax. M,x is variable and M is lambda term 

3. t= (MN),M and N are both lambda terms 
Hence, there are 3 kinds of À terms. 

e Variable(referencing lambda expressions) 

e lambda abstraction(defining functions) 


e applications(invoking functions) 


Reduction Basic lambda calculus has no “built-in” functions. The mean- 
ing of lambda expressions is defined by how expressions can be reduced. 
There are three kinds of reductions: 


e a — conversion : changing bound variables, for example 
Ary.ry = Apq.pq 
e 5 — reduction : applying functions to their arguments, for example: 
(λα.α)υ = y 


e 7 — conversion : if two functions yields the same result for all their 
arguments, they are the same. for exmple: 


Au (f) = f 


if f doesn't contain 2. 


Free and Bound Variables In an expression, each appearance of a vari- 
able is either “free” (to A) or “bound” (to a A). For example, x is free in the 
expressions Aqp.x but not in expression Ary.xyxy. 


Normal Form A normal form term is a A term that does not contain 
any reducible expression, which means no 8 — Reduction can be applied to 
this term. If a À term that can become a norm form term, after a finite step 
of reductions, is called normalizable. For example: 


(Aaa b) > b 


where the last term is a À norm form. 
Some À terms are not normalizable. For example: 


(Az.22)(4y yy) 


. Applying a 8 — reduction to this term always yileds (Ay.yy)(Ay.yy), 8 — 
reduction can always be applied to this term. 


Weak Norm Form: A A term has no reducible expression left, but its 
sub-A term can still be reduced. For example: 


Aabe.((Ax.a(Ary))bc) 


Evaluation Strategies Evaluation Stategies are used to evaluate a A ex- 
pression. Evaluation on an expression can terminate or not depends on the 
choice of evaluation strategies. Leftmost strategy Reduce left most redu- 
ciable expression first. This is called call-by-name, i.e. functions are called 
without evaluating their inter A terms. 


(Az.z)((Az.zz)(ÀAz.zz)) - z 


If a À expression, through a finite step of reduction, can become a À norm 
form term, the left strategy reaches this normal form. 
Rightmost-innermost strategy Evaluate the innermost À terms among 
the rightmost reduciable expression. This is called ca11-by-value, i.e. sub- 
À terms are evaluated before being reduced in a higher level À term: 


(Az.z)((Az.zz)(Àz.zz)) > 
(Az.z)((Az.zz)(Az.zz)) >- 


Evaluation of inter-most reduciable expression ((Az.zz)(ÀAz.zz)) yields itself 
and evaluation does not terminate. 


Logic and predicates Church booleans are used for boolean values true( T) 
and false(F) as follows: 
T = ArAy.x 


F = AxAy.y 


Some logic operators can be defined by Church booleans. 
AND = AxAy.xyx 


T = Am 
T = Az.z ET 


A predicate function can be defined with Church booleans. For example, 
Z is a predicate, which return T if its argument is Church numberal 0 and 
return F if it is not. 


Z = Aq A RT 
PRED = (An.Af.Ax.n)(Ag.Ah.h(g f )) (Au.x) (Au.u) 
Recursion To define a recursion function in A — Calculus, it needs a 


auxillary function Y to reference the recursion function itself becuause of 
À — Calculus's anonymity. 


Y = (Ay.(Az.y(xz))(Az.y(xz)) 
Applying Y to a function R yields: 
Y R = Ax.R(zx)(Ax.R(zz)) > R((Az.R(xz))(Az.R(xx))) ^ R(Y R) 2 R(R(Y R)) 


> R(R(R(...(Y R)) 


This means the function R is evaluated using the recursive call Y R as the 
first argument. 


2.3 Turing Machine 


Turing machines are hypothetical machines that were created by Alan Turing 
in 1936 to explore the concept of what it meant computable|16]. It consists 
of an infinitely long tape divided into cells with symbols written on them, a 
head which can read symbols from cells, write symbols to the cells, move left 


Figure 1: Turing Machine Entity 


and right, a state register stores the state of the Turing machine. A stage of 
computation is determined by the content of the read cell and the state in 
the state register, head write symbol to the read cell, move left or right and 
then the state register enters a new state. Every Turing Machine has a halt 
state, if Turing Machine enters this halt state, it completes its computation 
task. 


Definition Following Soltys’ Notation[13], a (one-tape) Turing machine 
can be formally defined as a 4-tuple M = (Q, 3, T, ὃ) where 


ο Q is a finite, non-empty set of states which includes Qinit, Qacepet; Qreject 


e > is the set of input symbols, that is, the set of symbols allowed to 
appear in the initial tape contents 


e I is the set of tape symbols, and it is always the case that > CT 
ο ô is a transition function; ô : Q x T > Q xT x (Left, Right} 


An example of Turing Machine M which decides whether an input string has 
even Os. 


Table 1: Transition table for even Os 


State 
g0 gl 
BI T F 
ποπ μμ EUR 
TE dO Επ ος. 


In this case we have: 
Q = (40,41, T. F} 
dinit = 40 tine =E Qreject = F 
X = (0,1, B) 
r = {0,1, B} 


2.4 Computational Equivalance 


Computability is the ability to solve a problem efficiently. It is also a crucial 
topic in computer science. Computable functions are the basic objects of this 
field. As to what is computable, different mathematicians gave their different 
Answers. Intuitively, a function f from natural numbers to natural numbers 
is called computable if it can determine the value of f(21,22,--- , £n) for 
any argument z,,25,:--: ,T, given a list of instructions. The most widely 
studied computation models are the Turing Machines and general recursive 
functions, and the lambda calculus, all of which have the same power about 
computability. 


Proof Outline 
e A turing machine program (M) is partial recursive. 
e General recursive function can be reduced to A function. 


e À function can be simulated by Turing machines. 
1. Every turing machine program (M) is recursive. 


First of all, some recursive functions are listed in an intuitive manner 
for better understanding the proof. 
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od(x, y) = 0 ifz = 0 
d(x + 1, y) = mod(x, y) + 1 if mod(x, y) + 1 Æ y else 0 
(e) exp(x, 0) — 1 
exp(x, n+1) = exp(x, n) 
(f) log(0, x) = 0 
log(n, x) = 1 + log(quo(n, x), x) 
(g) flog(c, n) = 0 if mod(c, n) Z 0 else flog(c, n) = 1 + flog(quo(c, n), 
n) 
GÓdel numbering is used to encode the Turing Machines. The Turing 
Machines are restricted to to the alphabet {0,1}, and 0 is used to take 
place of black cell. Then, a turing machine tape can be shown by binary 


numerals. 
Given a configuration of a Turing Machine, e.g. A configuration is 


* x 


0 0110 11/10 1111010 


t 
qí 


Turing Machine Configuration 


coded as the triple of integers (l, q,r) where q is the state number (e.g. 
7), l is the tape contents to the left of the tape arrow interpreted as 
a binary integer(e.g. 10 which is 2), and r is the tape contents under 
and to the right of the arrow interpreted as a binary number reversely 
(e.g. 1011 is interpreted as 1101 which is 13). The code for the above 
configuration is 


GEN Ij = 92. . pe 


1, q, r can be recoverd from c using recursive function flog: 
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(a) 1 = left(c) = flog(c, 2) 
(b) q — state(c) — flog(c, 3) 


(c) r — right(c) — flog(c, 5) 


A computation task is coded by the GÓdel number of a sequence: 


((lo, qo; ro), (ἰι, q, Ti); pese. ins Gist) 


The code shows every thing about the each configuration, but says 
nothing about how a configuration transfers to another. Consider a 
Turing Machine < M > that computes function f(x), consecutive x 
+ 1 1s as input for the Turing Machine, f(x) + 1 consecutive 1s for 
its output. When the Turing Machine starts its computations, the left 
side of the tape is completely blank, the right side is 11---1, a block 
of z + 1 digits 1 with the head with at leftmost 1. 


Thus the left number at the start of < M > s computation of f(x) is 
0, and the right number will be 

exsub(x) = 2**1—1 
Note that exsub is a composition of Exponentiation function and Trun- 
cated Subtraction in formular 2.1 which is a partial recursive function. 


When A Turing Machine performs one step, the left and right numbers 
change based on what symbol is being read, as well as on what action 
is performed. The read number either 0 or 1, and the right number on 
the tape is interpreted reversely, it can be calculated by its remainder 
of 2. If the right number is r, then the symbol read will be 


read(r) = mod(r, 2) 


Here,mod is a function to compute remainder which is a partial recur- 
sive function. 


Let | and r be the old left number and old right number, l and 7 be the 
new left number and new right number. Suppose the action is to write 
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a 0 to the read cell. If there was a 0 in the read cell, the content of the 
cell does not change. So, | = l and r = r. If the symbol in the read 
cell was 1, the right number decreases 1, | = | and F = r—1. Then, 
r = r—read(r) for this action. Similaryly, for action to write a 1 to the 
read cell. If there was a 1 in read cell, | = | and 7 = r. If there was 
a 0 in read cell, / = l, and right number increase 1 7 = r + 1. Then 
r — r + 1—read(r) 

Next, consider functions when (M) moves left or right. For action to 
move left, r appends the last digit of l, that is r = 2r + mod(l,2). For 
left number, it drops its last digit, that is | = quo(l, 2). The same logic 
can be used for action to move right, then barl = 2ἱ + mod(l, 2) and 
barr — quo(r, 2) 

Let writing 0, writing 1, moving left, and moving right actions be num- 
bers 0, 1, 2, 3, and action number is a then the new left number will 
be given by 


l ifa-0ora-1 


newleft(l,r,a) = 4 quo(l, 2) ifa=2 (1) 
2l + mod(r,2) ifa=3 


Similarly, the new right number will be given by 

r—read(r) ifa = 0 
r+1—read(r) ifa =1 
2r + mod(l,2) ifa=2 
quo(r, 2) ifa=3 


(2) 


newright(p, τ, α) = 


When (M) halts, it ends with a standard configuration where left 
numberal is 0 and right numberal is f(x) + 1 consecutive 1s. The right 
number is kept tracked through computations. Then right number 
r = 2/00 1 when (M) finishes its computations, and f(x) will be 
given by 

value(r) — log(r, 2) 


Here log is the partial recursive function, so value is also partial recur- 
sive. 
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So much, for the moment, for the topic of coding the contents of a 
Turing Machine Tape. The coding for Turing Machines transition rules 
as follows: 


M = 410, 910, Q11, 411, 420, 0420, 421, Q21 ^ ` * Gk0; Qk0; Ωκι» Vk 


and O will be used as halt state not coded in m. Where k is the number 
of state of Turing Machines and a;; <= ὃ iis Turing Machines’ current 
state and j is the read symbol. Let m be the single code number for 
this sequence: 

m = 94103410 50117411... 


Then what action to perform and what state to enter when in state q 
and read symbol read(r) will be given by: 


action(m, q,r) = flog(m, C(4(q—1) + 2 x read(r))) 
newstate(m, q, τ) = flog(m, C(4(q—1) + 2 x read(r) + 1)) 
Now, turing machine configuration and coding functions of each com- 
ponents have been defined. Next, consider a partial recursive func- 
tion code(m, x,t) that give the code c for the the configuration after t 
stages of computation with machine code m and function f(x)'s input 


z. Clearly, at Turing Machines start their computations, the initial 
configuration code c is given by 


Co = code(m, z,0) = (0,1, exsub(x)) = 29315ezsub(z) 


that is left number is 0, state is 1, and right number is ersub(z). 


A procudure to get code c, from c, as follows: 


1) L = leftla) q = statela) m= righttes 


2) a, = action(m, qu, ri) 


4 


) 

3) qui = newstate(m, qi, Τι) 
) liga = newle ft(a;, lt) Tipi = newright(a,, ri) 
) 


5) cua = (lesa, M41, tria) 
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Thus, a function from c, to cep is defined as follows: 


Cr41 = getcode(m, σι) 


where getcode is a composition of the functions left, state, right, action, 
newstate, newleft, newright, and tuple, and is therefore is a partial re- 
cusive function. 


The function code(m, x,t), giving the code for the configuration after 
t stages of computation, can then be defined by partial recursion as 
follows: 


code(m, z,0) = (0, 1, exsub(x)) 
code(m, x,t + 1) = getcode(m, code(m, z, t)) 
It follows that code is itself a partial recursive function. The machine 
will halt when state(code(m, x,t)) — 0, and will then halt in standard 
position where right number is f(x) + 1 consecutive ls. If the ma- 


chine halts in standard configuration at time t, then the output of the 
machine will be given by 


output(m, x,t) = value(right(code(m, x, t))) 
Then t will be given by 


the least £ such that state(code(m, x,t)) — 0 if such a t exists 
undefined otherwise 
(3) 
This function is obtained from compoisition and minimisation, thus it 
is partial recursive or total recursive. 


halt(m, z) = I 


Let f'(m,x) = output(m, x, halt(m,x)), then f'(m, x) is recursive. If 
(M) computes f(x), then f(m,x) computes f(x), so (M) is recursive. 


. partial recursive functions can be reduced to lambda terms. 
Here, we show how basic functions and operators from partial recursive 


function can be represented in lambda terms. 
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Integer, Constant, Projection, Successor 


e Church numerals are used to represent integers in À — Caculus. 
Church defined natural numbers in À — Caculus as follows: 


0e = Àf.Az.z 

le = A RAE fx 

D= Ai AUS OE) 

3e = Af Ax. f (f Cf) 


ne = Af. Ax. f(f(f ++) o) 
sK p 


TL 


e The constant functions return a constant no matter what their pa- 
rameters that is C"(x1,z5,:-- , £k) = ne. This can be represented 
by the lambda expression Az;,2x2,:-- , Ek-Ne, 


e The projection functions takes a tuple of numbers as input and 
return an integer in this tuple, PF = (zi,25,--- , £k) = Ti. This 
can be represented by the À expression A7izə-:: Tk.T; 


e The successor function take an integer n as input and returns 
n +1, that is, S(n) — n + 1, this can be represented by the 
lambda expression An¿.A f. Az. f (nefe), 
Composition, Primitive Recusion, Minimization 


e Composition 
The composition of function h with the functions gi, 92,*** , Qm; 
where h is a (m-place) function, and each of g function is a k-place 
function. Then the composition is 


Jt, ta, EM, = h(gi(z1, ta, - ins SER) ro hay Ta, ye ug), sem Om X1, 22,777 Zk): 


This can be represented by lambda expression 


Ahg192 μυ», vy. h(gio 1x2 Y Tp) (922172 e Tp) US (JmT1T2 reo Tp) 
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e Primitive Recursion p”(g,h) is the function f such that: 
f(0,21,22--- , Ek) = οίσι, σοι"... , Tp) 
Fly +1,21,%2>>* ti) = h(y FY, 1, ο) 
This can be represented by the following lambda expression: 
Aghzizo::: za. Y (Af1.Z(911%3 ++: x,)(hzizo s x4 )( Px(f (Px)))) 


where Y is fixed-point, P is the predecessor function and Z is used 
to test whether its argument is 0. 


e Minimization j(f)(xix2--- £n) returns the smallest z such that 
JT i122; 3 Z) = 0 
This can be represented by the following lambda expression: 
Afzizo:- za. (Y (Ahz.Z(fz4izə:  xuz)z(h(Sz)))Z) 


where S is Successor function 


Now, we have shown that general recursive function can be re- 
duced to lambda calculus. 


3. lambda calculus can be reduced to Turing Machine. 
Before thinking about the Turing machine itself, it is important to rep- 
resent a À term in a way that makes their evaluation easy. In particular, 
we wish to avoid a-conversion. De Bruijn indices allows us to do that. 


De Bruijn indices The unnamed A-calculus is defined as follows: 
M ::=n|AM|(MM) 


where n — natural numbers greater or equal to 0 are variables. The 
n indicates the position of the A binding this variable, starting from 
inside. For example: 


Ar.Ag.r = AM Ate 2). = AQ. 0) 
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Encoding we use alphabet X = (A, B,(,), 0,1, ©}, and translate a 
lambda-term M into a tape M in the following way. 


© ifnisa free variable 
— |QE ifnisa bound variable 


AM := AM 
(M N):-(M) (N) 


where E is the binary representation of the De Bruijn index of that 
occurrence. Consider M = (Aq.q)(Aq.Ap.q), then its 


De Bruijn form is (A0) (AA1), and our tape for this term is (A C) 0)(AÀ O 1). 


The Turing Machine (Mr) operates by iteratively performing the fol- 
lowing step. Take the expression (Ar.Ay.ryy)(Ay.y)(Az.x) as an exam- 

ple, this expression can be transformed into (AA @) 1@0@0)(A©® 0)(A © 0) 
as a input string for a TM (My). 


Step 1: The (Mz) looks for the first pair of parenthesis. Here, first 
pair is in the sense of the first ( we find, combined with its close 
counterpart. If we cannot find a pair of parenthesis, the machine 
halts. 


Step 2: Locate the second pair of parenthesis with the similar definition 
of step 1. If the second pair can not be found, then erase the first 
pair of parenthesis. Otherwise, erase the first occurrence of À and 
replace every occurrence of the bounded variable by the content 
inside the second pair (including the parenthesis), then erase the 
second pair of parenthesis and whatever inside it. 


Step 3: Erase first parenthesis if no A can be found inside it (without 
looking nested parenthesis). 


Step 4: Concatenate the left part and the right part. In the example, the 


tape becomes (A(AG) 0) (00 (90)(A 0) 


Every time the sequence of steps is essentially a normalization step. So, 
(Mru) halts on M if and only if M is normalizing and the output will 
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be the normal form of M. In this example, the tape evolves as follows: 


ο ο ο Qoa Qo 
NOYO ο το 
ο ο οι 
¿00009 

NOL 
Turing Machines can intrepte À — Calculus, and General recursive functions 
can be reduced to À — Calculus. Hence, a turing machine simular that can 
animate the computing process of Tuinr Machines, is not only beneficial for 


learning the concept of Turing Mchines, but also A — Calculus and General 
recursive function, and from a higher level, computable funcitons. 


( 
( 
( 
( 
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3 Turing Machine Simulator 


Turing Machines are imaginary devices for mathematical computation, which 
perform their computations by manipulating symbols on a finitely length of 
tape according to a set of transition functions. Turing machines are models 
that can simulate any computer algorithm no matter how complex it is. 

Nowadays, Turing Machines are used to help people gain a better un- 
derstanding of algorithms and how a computer works, which is why this 
simulator was created. 


3.1 Code 


Before going through the simulator's functionality, it is imperative to provide 
the data structure to be used. 


Data Structure 


e Node 
class Node: 
def | init | (self, letter): 
self.letter - letter 
self.R - None 
self.L - None 
# simulate ‘‘cell’’ in the turing machine?s tape 
e Action 


class Action: 
def | init. (self, letter, go to, state): 

self.write letter = letter \\ write letter 
self.go to = go to NN movie direction 
self.next state = state NX next state 
self.length - len(letter + go to + state) 

# this will be used to calculate cells? width 

# of a transition table 
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# which simulates instruction part of each transition rule 


e Tape 


# A turing machine takes a string as input 
# and we use double linkedlist to simulate the tape 
class Tape: 
def | init | (self, stri): 
self.arrow node = None 
self.length - O 
self .constructor(str1) 


def constructor(self, stri): 
if not stri: 
raise RuntimeError(’input cannot be empty?) 
pre.node - None 
for char in strí: 
self.length += 1 
cur node - Node(char) 
if self.arrow node is None: 
Sself.arrow node = cur. node 
if pre node is not None: 
cur node.L - pre. node 
pre.node.R - cur. node 
pre.node - cur. node 


Utils 


e parser 


# simulator takes a file as input 
#to construct transition rules. 
def parse tm(file): 
res - [] 
with open(file) as f: 
strs - f.read() 
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rules = strs.split(";") 
for i in rules: 
rule = i.split( 
if len(rule) -- 
res.append(rule) 
return res 


e tape printer 


def print tape(node): 
while node.L is not None: 
node - node.L 
res - "" 
while node is not None: 
if node.letter !- " ": 
res += node.letter 
node - node.R 
print(res) 
# this is used to print out the result given by 
# a string running on a turing machine 


Main Function 
— Construct transition table 


def construct transition table(rules): 
init state - None 
table = dict() 


Since ó is a transition function; 6: Qx T > Q xT x (Left, Right} 


for i in rules: 
key = i[0] + "-" + iff] 
4 i[0] for current state 
# i[1] for reading letter 
if init state is None: 
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init state = i[0] 
if key not in table: 
table[key] = Action(i[2], i[3], i[4]) 
# i[2] for writing letter 
# i[3] for next state 
* i[4] for moving direction 
else: 
print("Transition table exists key conflict ") 
return table 


tm file - sys.argv[1] 

init state - sys.argv[2] 

tm rules - parse tm(tm file) 

# parse file to transition rules 


def run tm(rules, input str, init state-None): 
transitions - construct transition table(rules) 
stop = ["T", "F", "H"] 
# terminate states 
# T: accept, F: reject H: halt 
if init_state is None: 
init state = rules [0] [0] 
# if init_state is not provided, 
# use current state in the first transition rule 
# as initial state 
cur_state = init_state 
# to record runing steps for turing machine 
step = 0 
tm_tape = Tape(input_str) 
arrow_node = tm_tape.arrow_node 
cur_ins = cur_state + "-" + arrow_node.letter 
# current instruction 


while cur_state not in stop: 


step += 1 
if cur_ins not in transitions: 
break 
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arrow node.letter - transitions[cur ins].write letter 
if transitions[cur ins].go to == "L": 
if arrow node.L is None: 
arrow node.L = Node(" ") 
arrow node.L.R - arrow node 
cur ins = transitions[cur ins].next state + "-" N 
+ arrow node.L.letter 
arrow node = arrow node.L 
else: 
if arrow node.R is None: 
arrow node.R = Node(" ") 
arrow node.R.L = arrow node 
cur ins = transitions[cur ins].next state + "-" ÓN 
+ arrow node.R.letter 
arrow node - arrow node.R 
cur state = cur ins[:cur ins.index("-")] 
return step, cur_state 
# return steps and final state 


The code above consists of core logic of building a turing simulator without 


GUI part. 


3.2 Configure a transition table 
According to the transition funciton: 

9: QxT>QxTx(Left, Right} 
A turing machine file is composed as below: 


α0 «1 R q0; gO 1 1 R ας; 
q0 R H; q0 0 * L qi; 


qi 1 1 L al; qi _ _ R q2; 
ql 0 0 R q2; q2 1 0 R q0; 
qa 0 0 R q2; q2 * 0 R q0; 
q2 _ ΒΗ; qi κ * R H; 
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This is a turing machine which can be used to do simple sort, given a string 
in the alphabet X = {0,1}, yields a string all 05 are before 1s. A transition 
is defined by a tuple with 5 symbols(C, R, W, D, N) where 


C: current state 


R: reading letter 

e W: writing letter 

e D: moving direction 
e N: next state 


0. 
, 


is used as delimiter to separate each transition. 


3.3 Usage 


Run python view.py «Your Turing Machine Configuration file> 
through terminal. Once you entered this program, you will see an overview 
of this simulator as Figure 2: 
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State: Step: 


2-R-H | 2-R-q3 | 2-L-q6 | 2-R-H | 2-L-q5 | *-R-q3 | #-L-q4 


-R-q2 | -L-q4 | -R-H -R-H | -R-q0 | _-R-H -L-H 


1-L-q1 | 1-R-q3 | 1-L-q6 | 0-R-q0 | 1-L-q5 | 1-R-q0 | #-L-q6 


0-R-q2 | 0-R-q3 | 0-L-q6 | 0-R-q2 | 0-L-q5 | *-L-q1 | £-L-q5 


*-R-H. | ΒΗ | 1-R-q0 | 0-R-q0 | *-L-q1 | 1-R-q0 | 2-R-q0 


#-R-H | #-L-q4 | #-R-H | #-R-H | #-R-H | 2-R-q0 | #-R-H 


stop 


< < < «arrow speed»»»»»»» <<<<<<arrow_position>>>>>> 
70 n 1 1 
input string: ok - 


EL Η 


Figure 2: Turing Machine Simulator Overview 


Now we introduce each part of this simulation. Going from top to bottom: 


State: Step: 


Figure 3: Turing Machine Tape 


first, as it shows in Figure 3 we see a tape with empty cells that are meant 
to be filled with letters from its alphabet X, in this case for turing machine 
doing color sort, which will a string all 1s in the middle, all 0s before 1s, all 
2s after 1s, given an input string composed by (0, 1, 2}. 
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There is an fixed arrow which enables you to see the tape moving anima- 
tion when the machine is executing your code. 


qi q3 q6 q2 q5 q0 q4 
2 | 2-R-H | 2-R-q3 | 2-L-q6 | 2-R-H | 2-L-q5 | *-R-q3 | #-L-q4 


_-Req2 | -L-g4 | -R-H | -R-H | _-R-q0 | -R-H | -L-H 


1 | 1-L-q1 | 1-R-q3 | 1-L-q6 | 0-R-q0 | 1-L-q5 | 1-R-q0 | #-L-q6 


0 | 0-R-q2 | 0-R-q3 | 0-L-q6 | 0-R-q2 | 0-L-q5 | *-L-q1 | #-L-q5 


* | *R-H | “ΒΗ | 1-R-q0 | 0-R-q0 | *-L-q1 | 1-R-q0 | 2-R-q0 


# | #R-H | #L-q4 | Z-R-H | #R-H | Z-R-H | 2-R-q0 | Z-R-H 


Figure 4: Turing Machine Transition Table 


A transition table in Figure 4 is used to show your transition rules of your 
turing machine. 
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ql q3 q6 q2 q5 q0 q4 
2 | 2-R-H | 2-R-q3 | 2-L-q6 | 2-R-H | 2-L-q5 | *-R-q3 | #-L-q4 
— | -R-q2 | _-L-q4 | -R-H | -R-H | _-R-q0 | -R-H | _-L-H 
|| o  [tR-q3 | 1-L-q6 | 0-R-q0 | 1-L-q5 | 1-R-q0 | #L-q6 
0 | 0-R-q2 | 0-R-q3 | 0-L-q6 | 0-R-q2 | 0-L-q5 | *-L-q1 | #L-q5 
* | *R-H | “ΒΗ | 1-R-q0 | 0-Β-αο | *-L-q1 | 1-R-qO | 2-R-q0 
# | #R-H | #L-q4 | #R-H | #R-H | #R-H | 2-R-q0 | 4-Β-Η 


Figure 5: Turing Machine Transition Table Highlighted 


A transition rule is highlighted(Figure 5) while the machine is executing 


it. 


input string: 


Figure 6: Turing Machine Operation Box 


Now we introduce the functionality of each part: input box,play, stop, 
next, changing speed, set arrow position(6). Let's go over them one by one: 


1. Input Box: 
This allows you to feed different inputs into this program at each run. 
After you give an input to this program, clicking OK will load your input 
to the tape. 


2. Play 


This is used to run the code and continue the turing machine after you 
enter Step Mode 


3. Transition Table 
It shows the actual code of the turing machine. With hightlighted cell 
while the machine is ruining, it enables us to know which code snippet 
is running. 
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4. Next 
'This is used for taking one step forward. Once we load the code in the 
machine it will get clear. As an instructor, it's quite useful to explain 
what is happening on the machine. 


5. Arrow Position 
It servers three main functionality. 


(a) set up initial arrow position 
It's convenient to set up initial arrow position with just intuitive 
operations, instead of writing turing machine transition rules. 


(b) moving position arrow after turing machine terminated can help 
us see the whole final output. 


6. Speed 
This allows you to change the moving speed of the arrow 


7. Stop 
This is used to terminate your program. 
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4 Universal Turing Machine 


4.1 Background 


The Turing Machine Similator is a software that takes Turing Machine pro- 
gram and the program's input decription as its own input, and it animates 
the TM program's computing process. Here, the Machine Simulator actu- 
ally serves as a Universal Turing Machine. Before computers, there were no 
softwares avaiable. It brought a problem for Turing Machines. For each new 
computation task, a different Turing Machine must be created to serve the 
purpose. It is neither flexible nor cost-effective for hardwares. This is why 
Alan Turing created the idea ofUniversal Turing Machine . A Univer- 
sal Turing Machine(UTM) is a Turing machine(TM) that can simulate 
an arbitrary TM on arbitrary input by taking description of the TM be- 
ing simulated and its input as input and performing action based a set of 
transition functions. 


4.2 Encoder 


First, to create a description for a TM being simulated, it requires an encoder 
to UTM be able to recoginize this description. Here, we introduce how we 
encode (M)(Turing Machine) to a (M) description and its input which are 
concatenated as a string that we can load it on (UT M)'s tape. 


1. Schema(structure) 
We still use the same symbolism for (M) we introduced previously. 
We add Caret ^ to these symbols denote encoded symbols and other 
symbols such as ., : are used literally. A description should look like 
below: 


2. Encode TM alphabet 
Binary encoding is used in general where 


[E = FogallE lf 


For example: 
T= {B,0,1} 
then 


m» 
| 

E 

jm] 


B=00 0201 
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3. Encode TM state set 


The same encoding strategy is used for state set as encoding T'M aphal- 
bet. 


lI] = [loge QIN] 
For example: 

Q = (40,41, q2, q3} 
then 


4. Encode moving direction 


e O:left 
e light 


After encoding these parts, we place them in the schema structure, this makes 
a (UT M) input. We can still set up initial arrow position, by adjusting the 
position of symbol A. The (Motor ,,, as in Figure 7 can be a good a 
example to explain the encoder. g 


; Q@11R qd; gd _ ; q0 0 * L q1; q0 2 * R q3; q0 4 2 R QQ; 


qð * 1 R qð TI RIH 
q111Lqgql;q1l__Raq2;q100Rq2; ql x*xRH; OLAF RH: qi 22RH; 
q2 0 0 R q2; q2 * 0 R qð; q2 ΒΗ; q2 1 0 R q0; q2 # # R H; q2 2 2 R H; 
q3 0 0 R q3; q3 1 1 R q3; q3 2 2 R q3; q3 # # L q4; q3 _ _ L q4; q3 * * R H; 
q4 0 # L q5; q4 1 # L q6; q4 * 2 R q0; q4 # # R H; q4 2 # L q4; q4 _ _ L H; 
q500L435;qd511L435; α5 22Lq5; gbi * * L ql; qb Z RH; g5__ R QQ; 
g6 @ 0 L q6; q611L 36; q622L q6; q6* 1R q0; qo # # R H; σα. RH; 


Figure 7: Color sort transition rules 


1. state set: 


x:000 1:001 :010 0:001 2:110 72:101 


2. alphabet set: 


H:001 q0:000 g1:010 42:100 43:011 q4:101 q5:110 q6 
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: 111 


3. description in Figure 8: 


+ 000000^ 0000000011000, 0000010011000, 0000100101001, 0000110001010, 0001000001011, 
0001011001000,0100010011010,0100100101100, 0100110111100, 0100000001001, 0101011011001, 
0101001001001, 1000110111100, 1000000111000, 1000100101001, 1000010111000, 1001011011001, 
1001001001001, 0110110111011, 0110010011011, 0111001001011, 0111011011101, 0110100101101, 
0110000001001, 1010111011110, 1010011011111, 1010001001000, 1011011011001, 1011001011101, 
1010100101001, 1100110111110, 1100010011110, 1101001001110, 1100000001010, 1101011011001, 
1100100101000, 1110110111111, 1110010011111, 1111001001111, 1110000011000, 1111011011001, 
1110100101001 


Figure 8: Color sort transition description 


4. input: 


e original 


> 20112011 


e encoded input 


> 100.011.001.001.100.011.001.001. 
5. tape in Figure 9 


+ 000000” 0000000011000, 2000010011000 , 0000100101001, 0000110001010, 
0001000001011, 0001011001000, 0100010011010, 0100100101100, 0100110111100, 
0100000001001, 0101011011001, 0101001001001, 1000110111100, 1000000111000, 
1000100101001, 1000010111000, 1001011011001, 1001001001001, 0110110111011, 
0110010011011, 0111001001011, 0111011011101, 0110100101101, 0110000001001, 
1010111011110, 1010011011111, 1010001001000, 1011011011001, 1011001011101, 
1010100101001, 1100110111110, 1100010011110, 1101001001110, 1100000001010, 
1101011011001, 1100100101000, 1110110111111, 1110010011111, 1111001001111, 
1110000011000, 1111011011001, 1110100101001: .010>100.011.001.001.100.011. 
001. 001.010.010.010. 010.010.010. 


Figure 9: initial UTM tape 


4.3 Design 
1. Fetch Letter Turing Machine 


32 


Procedure Start from left end 


Step 1: Go to the right find symbol > 
Step 2: Go to the right to find the next symbol . 


Step 3: Go back to left find first O or 1 replace them with x, y repectively. 
If find > before any 0, 1 do step? 


Step 4: Go to the left find symbol ` 


Step 5: Go to the left find first O or 1 and replace them with x if we get 
x from step3, otherwise y. 


Step 6: From this position do stepl 
Step 7: Find next . 
Step 8: Go to the left reset all x,y to 0, 1 


Transition Rules (Figure 10) 


qo © 0 Rq0; qó x x R q0; qð y y R qo; qð 1 1 R qð; q@, , R qð; qd. . R qð; qo R qô; qÓ >> R qi; q0 : : R q0; q0 L — R q6; 
α1»» Βα]; αα χχΒαῖ; α1γγαῖ; α19111Βαῖ; αἱ 00 Βα]; α1. .Ι α2; α1 R qi; qi, , R qi; ql : R qi; qi _ κα; 
02:02 ο αυ L. 68; Q2 xk x E2502 y y L ο. > Rass de: E5025 qa πα q2 παλ q2: ; L g2: gl Raz 
q3 0 @ E:q3:.03 1-1 E q3; 03.5, ass q3 L 35; 915513; 33 ç . 15933 qs Xx L 3; QS y y 559325 03:278. Less 03 1 παπι 
q4 0 0 L αϑ; q4 1 1 L qá; qá , , L qá; qá ` ` L q6 4 > > L qá; qd..L Qá; qá Xx x L qá; qá y y L q4; qá š : L q4; 04 RU; 
q5 @ x R.Q8; QS 3 x R qU; Q5 x XE qb; 05 y y LaS qS > > R q5; a5). .R.q5; 5, ; R 45; q5 Rq5; q5 š R a5: Q5 L. Rad; 
q6 0 y Rq0; q6 1 y R qo; q6 x x L q6; q6 y y L q6; q6 > > R q6; 46. . R q6; q6 , , R q6; q6 R q6; q6 : R q6; q6 _ _ R q6; 
XLOR q7 y'1 R q7; q/ 0 0 R-qui q7 1 1 R qi QT. < L QG; q^, , R QT) q7 Βατ; gT > > R:q7+ 07: : R q7; q7 κα 
g8 x 0 L q8; q8 y 1 L q8; q8 O Ø L q8; q8 11 L q8; q8 ` ` L q8; q8, , L q8; qB. . L q8; q8 > > L q8; q8 : : L q8; q8 _ ΒΗ; 
Figure 10: Fetch letter TM 
Example 


e Tape configruation when the machine starts(Figure 11) 


3t 000000” 0000000011000, 0000010011000, 0000100101001, 0000110001010, 
0001000001011, 0001011001000,0100010011010,0100100101100,0100110111100, 
0100000001001,0101011011001, 0101001001001, 1000110111100, 1000000111000, 
1000100101001, 1000010111000, 1001011011001, 1001001001001, 0110110111011, 
0110010011011, 0111001001011, 0111011011101, 0110100101101, 0110000001001, 
1010111011110, 1010011011111, 1010001001000, 1011011011001, 1011001011101, 
1010100101001, 1100110111110, 1100010011110, 1101001001110, 1100000001010, 
1101011011001, 1100100101000, 1110110111111, 1110010011111, 1111001001111, 
1110000011000, 1111011011001, 1110100101001: .010>100.011.001.001.100.011. 
001.001.010.010.010.010.010.010. 


Figure 11: Color Sort Fetch letter TM Starts 
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e Tape configruation when the machine halts(Figure 12) 


# 000100" 0000000011000, 0000010011000, 0000100101001, 0000110001010, 
0001000001011, 0001011001000,0100010011010,0100100101100,0100110111100, 
0100000001001,0101011011001, 0101001001001,1000110111100,1000000111000, 
1000100101001,1000010111000,1001011011001, 1001001001001,0110110111011, 
0110010011011,0111001001011,0111011011101,0110100101101, 0110000001001, 
1010111011110,1010011011111,1010001001000, 1011011011001, 1011001011101, 
1010100101001,1100110111110,1100010011110,1101001001110, 1100000001010, 
1101011011001, 1100100101000,1110110111111,1110010011111,1111001001111, 
1110000011000,1111011011001, 1110100101001: .010>100.011. 001.001.100.011. 
001.001.010.010. 010.010.010.010. 


Figure 12: Color Sort Fetch letter TM Ends 


2. Match Instruction Turing Machine 
instruction is a tuple (Q,T') which decides the action of TM which is 


(Q, (Ie ft, right y, T) 


Procedure Start from the left end 


Step 1: Go to the right find first 0 or 1 and replace them with x, y repec- 
tively 

Step 2: Go to the right find symbol ^, if cannot find any 
0 or 1, stop. 

Step 3: Go to the right find first O or 1, and replace them with x, y 


repectively, if the symbol matches symbol from step 1, go back to 
the left end then, do stepl. Otherwise, do step4. 


Step 4: Mark all 0 and 1 with x, y until meet {,} or {:}. If (, then go 
to the left find symbol (^ ), otherwise stop(this means cannot find 
instruction in transition table in the sense of simulating a turing 
machine). 


Step 5: Reset x, y to 0, 1 to the left end 
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Transition Rules (Figure 13) 


qð O x Rq1; qð 1 y R q2; qa x x R qd; qð y y R qd; qð RH; qU, , R q0; qd. . R qo; qd: : R qo; qð > > R qð; q0 _ _ Rae; 
qi x x R ql; 01 0 0 R al; gi 3 1 R;q3; ql y y R q; q1 RÆ ql,» R qis qi. a R qhu qt : rR qhip q1 >> R qi: αἱ. καὶ, 
q2 @ @ R q2; q2 11R q2; q2 x x R q2; q2 y y R q2; @ ` "` R g4; q22,,Rq2; q2..Rq2; q2::Rq2; q2»»Rq2; q2__R q2; 
q3 x x R q3; q3 y y R q3 6, Rah q3 0 x L q; 3 3 y R q6; ας σι . R q3; q3: z: R g3: >> R q3; q3 Ran 
q4 x x R q4; q4 y y R q4; q4 , , R q4; q4 1 y L q5; q4 0 x R q6; q4 ` ` R q4; 44. . R q4; q4 : : R q4; q4 > > R q4; q4 _ _ R q4; 
q5 ` ` L q5; q5 x x L q5; q5 y y L ass q5, , L q5; q5 _ _ R q0; q5 0 0 L q5; q5 1 1 L q5; q5 : : L q5; q5 > > R q5; q5.. L q5; 
q60xR q6; q6 1 y R q6; q6 , , L q7; q6 : : R H; q6 x x R q6; q6 y y R q6; q6 . . R q6; q6 > > R q6; q6 ` ` R q6; q6 _ _ R q6; 
SE Q yyuqu q 0 e Ë A SS 57 αλα)... 072: : Ü Q? aT SS L qhi SEA 131} 
q8 x O L q8; q8 y 1 L abi qS Βαθ; GS @ OL α8; q8 1 1 L a 8.. L 8; q8 : :  q8; 8» > L q8; q8 "` ” L 'q8; qü , , L q8; 
Figure 13: Match Instruction TM 
Example 


e Tape configruation when the machine starts(Figure 14) 


# 000100" 0000000011000, 0000010011000, 0000100101001, 0000110001010, 
0001000001011, 0001011001000,0100010011010,0100100101100,0100110111100, 
0100000001001,0101011011001, 0101001001001,1000110111100,1000000111000, 
1000100101001,1000010111000,1001011011001, 1001001001001,0110110111011, 
0110010011011,0111001001011,0111011011101,0110100101101, 0110000001001, 
1010111011110,1010011011111,1010001001000,1011011011001,1011001011101, 
1010100101001,1100110111110,1100010011110,1101001001110,1100000001010, 
1101011011001, 1100100101000,1110110111111,1110010011111,1111001001111, 
1110000011000,1111011011001, 1110100101001: .010>100.011. 001.001.100.011. 
001.001.010.010. 010.010.010.010. 


Figure 14: Color Sort Match Instruction TM Starts 


e Tape configruation when the machine halts(Figure 15) 


# XXXyXX ΧΧΧΧΧΧΧΧΥΥΧΧΧ, XXXXXY XX Y Y XXX , XXXXyXXyXyXX , XXXXyyXXXyXyX y 
xxxyxx0001011, 0001011001000,0100010011010,0100100101100,0100110111100, 
0100000001001, 0101011011001, 0101001001001, 1000110111100, 1000000111000, 
1000100101001, 1000010111000, 1001011011001, 1001001001001, 0110110111011, 
0110010011011, 0111001001011, 0111011011101, 0110100101101, 0110000001001, 
1010111011110, 1010011011111, 1010001001000, 1011011011001, 1011001011101, 
1010100101001, 1100110111110, 1100010011110, 1101001001110, 1100000001010, 
1101011011001, 1100100101000, 1110110111111, 1110010011111, 1111001001111, 
1110000011000,1111011011001, 1110100101001: .010>100.011. 001.001.100.011. 
001.001.010.010.010.010.010.010. 


Figure 15: Color Sort Match Instruction TM Ends 
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3. Write And Move Turing Machine 


Procedure Start from right of the symbol * 


Step 1: Go to right find first O or 1 and replace them with x, y repectively 


Step 2: Go to right find > 


Step 3: Go to right find first O or 1 before {.} and replace them with x if 
fetched symbol from step 1 is 0, otherwise y. If cannot get 0 or 1 


before {.}, do step 5 


Step 4: Go to left find the first x or y do step 1 


Step 5: If fetched symbol from step 1 is 0, go to left to find >, replace it 
with {.}, then go to left again, find {.}, replace it with {>} and 


stop. 


Else replace current symbol (.) with >, then go to left to find > 


and replace it with 4.) and stop. 


Transition Rules (Figure 16) 


qð O x R ql; qð 1 yR q 

qi 0 O R ql; q1 1 1R ql; ql, , Ral; αἱ. . Rq; αἱ: : R ql; qi > > R q; 
PURA a2 4019019200205 R η; KAR = p R Q2 SRE 
q3xxRq3;q3yyRq3; q30x L q5; q3 1 x L q5; q3..L q6; q3 >> L q3; 
q6x 0 L q6; q6 y 1 L 6; q600Lq6; q611L 

q4 x x R q4; q4 y y R q4; q4 0 y L q5; q4 1 y L 

q8 x 0 L q8; q8 y 1 L q8; q8 . . L q; q8 O O L q8; 48111 q8; q8>. 
500 L q5; q5 11 Lq5; q5xxL q5; ας να, q5 >> L 95; q5.. 
700Lq7; q711Lq7; q7 x xR 0; q My Ra 


qô; q6 >. L q6; 6.» LH; q6 : 
q5; q4 . > L q8; q4 > > L q4; q4 : 
: : L q8; q8 ` ` Lq8; qa _L q8; q8, , L q8; 
+: Lq75q5,,Lq55q5__La5;q5* ` L 5; 
0; q7,,Lq5;q `` Rq; q: 


; q0 x x R qd; q0 yyRq;q0 , , Rq; ad. . Rq; qd: : R qd; qO >>Rq; q Rad; q^ "Ra; 
q1 x x R q1; q1 y y R q1; q1 _ _ R q1; q1 ` ` R q1; 
q2 x x R q2; q2 y y R q2; q2 _ _ R q2; q2 ` ` R q2; 


οι Lqug. Rg;g,.Lq5 


: Lab; q6 ` ` L q6; q6 Rab; q6, , L 46; 


: Lal; q4 "Lag; q4 Rat; gd, , L q4; 


1215075507 3 φας — E075 Q b > Lats 


Figure 16: Write And Move Letter TM 
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Example 
e Tape configruation when the machine starts(Figure 17) 


# XXXyXX ΧΧΧΧΧΧΧΧΥΥΧΧΧ, XXXXXy XXy Y XXX , XXXXyXXyXyXXy , XXXXy yXXXyXyX , 
xxxyxx0001011, 0001011001000,0100010011010,0100100101100,0100110111100, 
0100000001001,0101011011001, 0101001001001,1000110111100,1000000111000, 
1000100101001,1000010111000,1001011011001, 1001001001001,0110110111011, 
0110010011011,0111001001011,0111011011101,0110100101101, 0110000001001, 
1010111011110,1010011011111, 1010001001000, 1011011011001, 1011001011101, 
1010100101001, 1100110111110, 1100010011110, 1101001001110, 1100000001010, 
1101011011001, 1100100101000, 1110110111111, 1110010011111, 1111001001111, 
1110000011000,1111011011001, 1110100101001: .010>100.011. 001.001.100.011. 
001.001.010.010.010.010.010.010. 


Figure 17: Color Sort Write And Move TM Starts 


e Tape configruation when the machine halts(Figure 18) 


3 XXXyXX ΧΧΧΧΧΧΧΧΥΥΧΧΧ, XXXXXy XXy Y XXX , ΧΧΧΧΥΧΧΥΧΥΧΧΥ, XXXXy yXXXyXyX , 
xxxyxx0001011, 0001011001000,0100010011010,0100100101100,0100110111100, 
0100000001001,0101011011001, 0101001001001,1000110111100,1000000111000, 
1000100101001,1000010111000,1001011011001, 1001001001001,0110110111011, 
0110010011011,0111001001011,0111011011101,0110100101101, 0110000001001, 
1010111011110,1010011011111, 1010001001000, 1011011011001, 1011001011101, 
1010100101001, 1100110111110, 1100010011110, 1101001001110, 1100000001010, 
1101011011001, 1100100101000,1110110111111,1110010011111,1111001001111, 
1110000011000,1111011011001, 1110100101001: .010>100.011. 001.001.100.011. 
001.001.010.010.010.010.010.010. 


Figure 18: Color Sort Write And Move TM Ends 


4. Update State Turing Machine 


Procedure Start at > or from the left first{.} of > 


Step 1: Go to the left find symbol {:} 
Step 2: Go to the left find the first x or y 


Step 3: Go to the right find first O or 1 before symbol {:}, if meet {:} 


stop, otherwise go to right. 


Step 4: go to the left if the left symbol x or y, go to the right replace 


0, 1 with 0, 1 repectively. 
Step 5: Go to left end (for simplicity) 
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Step 6: Go to right to find first O or 1 before and replace them with x if 
fetched symbol from step 1 is 0, otherwise y. 


Step 7: Go to right to find symbol ^, then do step3 


Transition Rules (Figure 19) 


qa O Ø L qð; qO 11 L qð; σθ. . L qO; qO : : L q0; qO > > L qd; qO x x R q; qð y y R q1; q0 ` ` L qd; qa _ _ L qð; qð, , L q0; 
quien L α2» QL D y L 03:01, , ΒΗ; QL P p ΒΗ; ql X X R Q QE y y R qL QE > RAGU ql. ποσα — F qip ql 4 7 R ql; 
qox xot 02: q2 yy E-92: 02 5... E02: dz. > 115142: 02:0 970 02:02:11 1-92: 02 πα“; αρ. ια 92 S S W δρ αρ. Riad: 
q3 x x L 03:503 y y A 205203203 ada ος a qa ia ασια Κα“; π3’5 ο (0355030503 R 43; 
q4 © 0 R q4; q4 1 1 R q4; q4 x 0 R q6; qd y OR q6; q4 ` ^ R q4; q4 , , R q4; qd. . R q4; qd» > R q4; q4 _ _ R q4; qd : : R q4; 
45 @ @ R qS; QS 1 1 R qS; qS X 1 R Aas y 1 R qos ας RA: qS RG qS « < R GS; QS'> > κας RAGI ᾳ5|5 R ga 
q6 x x R q6; q6 y y R q6; q6 ` ` R q6; q6 , , R q6; q6 0 Ø L qð; q6 1 1 L qð; q6 : : L H; q6 _ R q6; q6 > > R q6; 46. . R q6; 


Figure 19: Update State TM 
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Example 
e Tape configruation when the machine starts(Figure 20) 


# XXXyXX ΧΧΧΧΧΧΧΧΥΥΧΧΧ, XXXXXy XXy Y XXX , XXXXyXXyXyXXy , XXXXy yXXXyXyX , 
xxxyxx0001011, 0001011001000,0100010011010,0100100101100,0100110111100, 
0100000001001,0101011011001, 0101001001001,1000110111100,1000000111000, 
1000100101001,1000010111000,1001011011001, 1001001001001,0110110111011, 
0110010011011,0111001001011,0111011011101,0110100101101, 0110000001001, 
1010111011110, 1010011011111, 1010001001000, 1011011011001, 1011001011101, 
1010100101001, 1100110111110, 1100010011110, 1101001001110, 1100000001010, 
1101011011001, 1100100101000, 1110110111111, 1110010011111, 1111001001111, 
1110000011000, 1111011011001, 1110100101001: .010>100.011. 001.001.100.011. 
001.001.010.010.010.010.010.010. 


Figure 20: Color Sort Update TM Starts 


e Tape configruation when the machine halts(Figure 21) 


3 011yxx ΧΧΧΧΧΧΧΧΥΥΧΧΧ, XXXXXY XX y Y XXX y XXXXyXXy XyXXy , XXXXy yXXXyXyX , 
ΧΧΧΥΧΧΧΧΧΥΧΥΥ, 0001011001000,0100010011010,0100100101100,0100110111100, 
0100000001001,0101011011001, 0101001001001,1000110111100,1000000111000, 
1000100101001,1000010111000,1001011011001, 1001001001001,0110110111011, 
0110010011011,0111001001011,0111011011101,0110100101101, 0110000001001, 
1010111011110, 1010011011111, 1010001001000, 1011011011001, 1011001011101, 
1010100101001, 1100110111110, 1100010011110, 1101001001110, 1100000001010, 
1101011011001, 1100100101000, 1110110111111, 1110010011111, 1111001001111, 
1110000011000,1111011011001, 1110100101001: .010.100>011. 001.001.100.011. 
θ01.001.010.010. 010.010. 010. 010. 


Figure 21: Color Sort Update TM Ends 


5. Clean markers (Figure 22) 


# 011100) 0000000011000, 0000010011000, 0000100101001, 0000110001010, 
0001000001011, 0001011001000,0100010011010,0100100101100,0100110111100, 
0100000001001,0101011011001, 0101001001001, 1000110111100, 1000000111000, 
1000100101001, 1000010111000, 1001011011001, 1001001001001, 0110110111011, 
01100910011011, 0111001001011, 0111011011101, 0110100101101, 0110000001001, 
1010111011110, 1010011011111, 1010001001000, 1011011011001, 1011001011101, 
1010100101001, 1100110111110, 1100010011110, 1101001001110, 1100000001010, 
1101011011001, 1100100101000, 1110110111111, 1110010011111, 1111001001111, 
1110000011000, 1111011011001, 1110100101001: .010.100>011. 001.001.100.011. 
001.001.010.010.010.010.010.010. 


Figure 22: Final Tape 


These four examples show how a Universal Turing Machine simulates 
for another Turing Machine for its one step Computation. At the be- 
ginning, we have initial state q0, reading letter 2, write letter x, moving 


39 


right, enter state q3. Before the Universal Turing Machine runs, on the 
left of its tape, we have state q0 represented by 000. When it begins 
running, the arrow > points 100 which represents 2 according to its 
encoded code (100 : 2). After simulating one step of that Turing Ma- 
chine, . The arrow > moved to the next {.} and points 011 which 
represents 0 here(Note the input is 20112011). Now, look at the left 
3 letters of the symbol >, we have 000 for * in the original Turing 
Machine. Now, left tape ends up with 011100, the first 3 letters rep- 
resent the original Turing Machine state, also according to its encoded 
code, it represents q3((011 : q3}). This is exactly what we want for the 
transition rule q0, 2, x, R, q3 


6. Creating UTM with 4 TMs above 


Procedure With the four Turing Machines we showed above. Arrow 
starts at the left most position. 


Step 1: Run Fetch Letter Turing Machine with current Turing Machine 
configuration. 


Step 2: Run Match Instruction Turing machine with the end configura- 
tion by running Fetch Letter Turing Machine. If this machine 
stops at its own step 4, then the Universal Turing Machine stops. 
Otherwise, do next step. 


Step 3: Run Write And Move Turing Machine with the end configuration 
by running Match Instruction Turing machine. 


Step 4: Run State Update Turing machine with the end configuration by 
running Write And Move Turing Machine. 


Step 5: Reset every z, y to 0, 1, then go to the left most symbol, pass end 
configuration to Fetch Letter Turing Machine, do step 1. 
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Transition Rules (Figure 23 and Figure 24) 


ql >>Rql; αἱ x xRql; ql y R ql; al 1 1 R ql; q 0 @ R q; qi. L 42; ql R qi; q1 , , R q1; ql $ R q atii C K Qs; 
q2 @ x L q3; q21yLq4;q2xxLq2;q2yyLq2; q2 > > R αὐ; q2" E22; 025, σαι, κά 2:592: ος R92; 
ο. ο οι. a 03-1 I1 /[503: 035, ^, L 037 03: — ο αὐ 5-3} 03: s Lq3; q3 x x L q3; q3y y L q3; q3 HL eae ark 
q40@Lq4; q411L σά; qá , , L á; qá ` ^ L abi á > > L qá; αὐ. L q4; q4 x x L q4; q4 y y L q4; q4 Σι qap ak πα 
q5 @ x R q0; q5 1 x R QQ; q5 x x L q5; @5 y y L q5; q5 > > R @5; q5. Rasa, , R q; Q5 "` ` R Q5; q5 : R q5; @ L. _ R q5; 
q6 @ y Rad; q6 1 y R q0; q6 x x L q6; q6 y y L q6; q6 > > R q6; 46. R q6; q6 , , R q6; q6 R q6; q6 : R q6; q6 .R q6; 
q? x Rq; q7 y 1R q7; q © 0 R q7; q211R q7; q7 . Las; ο ες R 0% q? ` R q7; q7 >> R αὐ; q? : R 97; q7 πα 
q8 x 0 L q8; q8 y 1L q8; q8 0 0 L q8; q8 1 1 L q8; q8 L q8; q8 , , L q8; q8 . . L q8; q8 > L q8; q8 : L q8; q8 R q9; 
Figure 23: UTM Part 1 
qL 0 x R q]; qi Ly R qk; gi ux x Rai; giy y Rai dai; , R gir qk. + R qip qi s κα qi > > Raqi; agi Ragi; qi R qi; 
qj00Rqj;qj11Raj;gj, , Βα]; αἱ... Βα]; αἱ: : R qj; qj > > R ql; qj x x R qj; qj y y R qj; αἱ. . Βα]; qj ` Rai; 
qk @ @ R qk; qk 1 1 R qk; qk, , R qk; qk. . R qk; ak: : R qk; qk > > R qm; qk x x R qk; qk y y R qk; qk _ _ R qk; qk ` R qk; 
qUx x R quis gi y y/R qU al ex L q q tX L an gi . < Lgo qt ai gi αἱ: z LE q; qt ` L qt qt Rab ali, Eq 
qo x OL qo; qo y 1 L qo; qo 0 0 L qo; qo 1 1 L qo; qo > . L qo; 4ο. > L qr; qo: : L qo; qo ` ` L qo; qo _ _ R qo; go, , L qo; 
qm x x R qm; qm y y R qm; qm 0 y L qn; qm 1 y L qn; qm. > L qq; qm > > L qm; qm: : L qm; qm ` ` L qm; qm _ _ R qm; qm, , L qm; 
qq x 0 L qq; qq y 1 L qq; qq . . L qq; qq 0 9 L qq; qq 1 1 L qq; qq > . L qr; qq: : L qq; qq ` ` L qq; qq _ _ L qq; qq , , L qq; 
qn @@L qn; qn11L qn; qnx xL qn; qn y y Lan; qn > > Lan; qn..Lqn; qn: : L qap; qn, , L qn; απ. _ L qn; qn” ^ L qn; 
qp 0.0 L qp; qp 1 1 L qp; qp x x R qi; qp y y R qi; ap, , L qp; qp ` ` R qi; qp::L qp; qp. . L qp; qp _ _ L qp; qp > > L qp; 
qr 9 0 L qr; qr Lorm areo E gr: gr gr qp > > Ë gi AE xx Rais ar yg Raka qr) στο ασ νεος 
qs ð x L qt; qs L qu; qs,,Rqy;qs:: Ray; QS X X R Qi qs y y Rqs; qs > > Rqs; qs..Rqs; qs __Rqs; qs ” ^ R qs; 
qt x x L qt; qt L qt; qt, , L qt; qt ` `L qt; qt 0 0 L qt; qt t; qt _ _ R qv; qt. . R qt; qt > > R qt; qt : : R at; 


qu x x L qu; qu 
qv 0 0 R qv; qv 
qw 0 0 R qw; qw 
qx x x R qx; qx 


R qv; qv x 0 R qx; qv y OR qx; qv ` ` R qv; qv 
R qw; qw x 1 R qx; qw y 1 R qx; qu ` ` R qw; qw 
R Pa 


pet 
» QU , , L qur qu ` ` L qu; qu @ @ L qu; qu 11 
i 
qx; qx ^ ^ R qx; ax R qx; qx 0 0 L qr; qx 11 


Lq 

La P 

Βαν; qv. - R qu; qv >> R qu; qv _ _ R qv; qv: : R qv; 
R qw; qu. . R qw; qw > > R qw; qu Βαν; qu : : R qw; 
L qr; qx š : L qr; qx. _ _ R qx; qx > > R αχ. R qx; 


P< PRPK< PPR 
e πας κ ς 
π 
a 
5 


qy 0 0 L qy; ay L qy; gy x L qy; gy y 1 L qy; αν , , L qy; αν . . Lay; qy : : L gy; αν ` ` L qy; qy > > L qy; qay _ _ R qð; 


Figure 24: UTM Part 2 


4.4 Usage and Example 


Mathematicians and computer scientists usually describe a Universal Turing 
Machine in the following format. 


In this case, users need to encode (Mim) and its input z, then run these two 
inputs on (Mutm). The program has implemented a subroutine for users to 
encode inputs. Users only need to provide a Turing Machine transition rules 
and its input for this UTM. 

Through terminal, run python utm.py - Your transition file> < Your 
input for your Turing Machine>. For example, 

python utm.py color sort.tm *>20112011” 

The quote for input for the input is required, since “>” is a keyword in most 
shells, such as bash, and zsh. ‘>’ is used to specify the arrow’s location on 
a Turing Machine. If users would like to have some space on both sides of 
the input string add ^ "tothem,likethis^ | ^ 20112011 .  " This 
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UTM program by default does not provide an animation for simulating a 
Turing Machine program(If a user really wants to see an animation process, 
he can use the encoder provided in this project, then get the encoded string 
and run command view.py utm.tm through terminal, next copy this string 
into GUI input box), since it will take too long to show this whole process. 
After the UTM program terminated, it will provide the information as below. 


UTM Result Information (Figure 25) 


tm-input tape: 
20112011 
tm-output tape: 
00111122 
tm-output steps: 
45 


encoding map: {'*': '@00' '001', ' ': '010', 'θ': "611", '2': '100', '£': '101', 'αθ': '000', 'H': '001', ‘qi’: '010', 'q3': '011', 'q2': '100', 'q4' 
: '101', 'q5': '110', 'q6': '111'} 

reverse state map: ('000': 'q0', '001': 'H', '010': 'q1', '011': 'q3', '100': 'q2', '101': 'q4', '110': 'q5', '111': 'q6') 

reverse letter map: ('000': 'κ', '001': '1', '010': ' ', 'O11': 'O', '100': '2', '101': ‘#'} 

utm-input tape: 

000000 0000000011000,0000010011000,0000100101001,0000110000010,0001000001011,0001011001000,0100010010010,0100100101100,0100110111100,0100000001001,01010110 
11001,0101001001001,1000110111100,1000000111000,1000100101001,1000010111000,1001011011001,1001001001001,0110110111011,0110010011011,0111001001011,011101101 
0101,0110100100101,0110000001001,1010111010110,1010011010111,1010001001000,1011011011001,1011001010101,1010100100001,1100110110110,1100010010110,1101001000 
110,1100000000010,1101011011001,1100100101000,1110110110111,1110010010111,1111001000111,1110000011000,1111011011001,1110100101001:.010»100.011.001.001.100. 
011.001.001.010.010.010.010.010.010.010.010.010.010. 

utm-output tape: 

x01010 XXXXXXXXY Y XXX ,JOOOOC XX y XXX , ΧΧΧΧΥΧΧΥΧΥΧΧΥ, ΧΧΧΧΥΥΧΧΧΧΧΥΧ, ΧΧΧΥΧΧΧΧΧΥΧΥΥ, , XXXy Xy Y XXY XXX , ΧΥΧΧΧΥΧΧΥΧΧΥΧ, XY XXY XXY XY Y XX , XyXXyyxyy YY XX , ΧΥΧΧΧΧΧΧΧΥΧΧΥ, XyXyXyyx 
yyXXy , ΧΥΧΥΧΧΥΧΧΥΧΧΥ, XXXyyXyyy Y XX , yxxXxxxyyyXxx , yxxXxyXXyXyXXy , ΥΧΧΧΧΥΧΥΥΥΧΧΧ, ΥΧΧΥΧΥΥΧΥΥΧΧΥ, ΥΧΧΥΧΧΥΧΧΥΧΧΥ, ΧΥΥΧΥΥΧΥΥΥΧΥΥ, ΧΥΥΧΧΥΧΧΥΥΧΥΥ, ΧΥΥΥΧΧΥΧΧΥΧΥΥ, ΧΥΥΥΧΥΥΧΥ. 
XyXy , ΧΥΥΧΥΧΧΥΧΧΥΧΥ, ΧΥΥΧΧΧΧΧΧΥΧΧΥ, ΥΧΥΧΥΥΥΧΥΧΥΥΧ, YXY XXY Y XY XY Y Y , YXyXXXyXXyXXX , ΥΧΥΥΧΥΥΧΥΥΧΧΥ, YXyyXXyXyXyXy ΥΧΥΧΥΧΧΥΧΧΧΧΥ, ΥΥΧΧΥΥΧΥΥΧΥΥΧ, ΥΥΧΧΧΥΧΧΥΧΥΥΧ, yyXyXxyxxx 
Y YX, yyXXXXXXXXXyX y yyXyXyyXyyXXy , ΥΥΧΧΥΧΧΥΧΥΧΧΧ, YY Y XY Y XY Y XY Y Y , YY Y XX Y XX Y XY YY , YY Y Y XX Y XXX Y Y Y , Y Y Y XX XXX Y Y XXX » Y Y Y Y X Y Y X Y Y XXY , ΥΥΥΧΥΧΧΥΧΥΧΧΥ: .010.011.011.001.001.001. 
001.100.100.010>010.010.010.010.010.010.010.010.010. 

utm-output steps: 

1200143 


Figure 25: UTM Info 


The steps of running the original Turing Machine and the Universal Turing 
Machine are provided to show how much efforts it takes for UTM to simulate 
a Turing machine given by specific inputs. Also, letter map and state map are 
provided in reverse direction of our encoding system, to help to check if the 
UTM output can interpret the original Turing Machine's terminated configu- 
ration. In UTM output tape, everything after {:} represents what left on the 
original Turing Machine when it halts. Moreover, the most left three letters 
on UTM tape represent the final state. According to the letter map and state 
map provided above, after translating it back, the result is the same as the one 
being simulated. For tape, we have 011.011.001.001.001.001.100.100.010 > 
which can map to 00111122 and arrow ended up at the right of the blank 
cell. For the state, we have x01 interpreted as 001, which presents A in the 
original Turing Machine. 
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5 Observation 


A Turing machine is an abstract computer.It use a tape which works like 
memory to store inputs and outputs. Also, it contains a set of transition 
functions which is the same concept as CPU instruction set. A Turing ma- 
chine perform its action based on its transition functions, and a computer 
does its tasks based on its instructions from a operating system and data in 
memory. 
In our example, it takes 1200143 steps for our 

Universal Turing Machine to get the same job done by the original Turing 
Machine with 45 steps. Formally, consider a TM with |Γ] 2 n and |Q| = m 
given arbitary input with the length of k. In our UTM, the tape length for 
this machine will be logn 4-logm -- 1 4-lognlogm(2logmn 4-2) 4-2 4- (k 4- 1)logn, 
since a Turing Machine Program P description is fixed, we can take k as 
the length for this UTM. Also, stages for Match Instruction and Update 
State never go through input description part on UTM tape, we take them 
out of our consideration. Then, stage for Restore, Fetch, Write take O(k), 
O(log(n)k), O(log(n)k). Overall, it takes O(k) for this UTM to simulate 
one step computation of a Turing Machine since logn is fixed. If it takes 
time t for a TM being simulated to finish its computation task, then it takes 
O(tk) for UTM to complete the simulation. And This different computing 
cost can be a good explanation of why Interpreting languages(code runs on 
a virtual machine) such as python, javascript, php are cross-platform and 
slower, while executable files from compling languages(complied code runs 
on a operating system) such as c, c++, go do not run on different operating 
systems, but faster. 
Note Java is also a Interpreting language from this point of view. Next, 
we compare C 4- + and Java to illustate the difference. First, consider the 
process of a c 4- 4- program compilation. 


e Processing: 
Copy the content from header files to the source file, replace constants 
with customized symbols defined by key word #define in the source 
file 


e Compiling: ComplieD code in the source file into assembler code. 


e Assembling: Assemble the code into the object code for a specific 
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platform 


e Linking: Object code file is used to produce an executable file. 


Notice all OS are different, so the compiled code is different. Moreover, 
each OS has different CPU instruction set architecture to interpret the final 
binaries, and the same binaries may have different meanings on different 
instruction set architecture, as it for different Turing Machines-faster but 
not portable. 

With java, things are different. Its virtual machine-JVM plays the role 
of such OS and hardware abstraction. JVM is not a library. Instead, it is 
a whole platform working on top of native OS, and its implementation is 
different for different OS. A Java compiler does not compile a Java program 
into CPU instructions. It compiles a program to the instructions of the 
virtual machine, byte-code. Also, the virtual machine interprets byte-code 
instructions as native code and executes it, in the sense that a Univeral Turing 
machine interprets a Turing Machine's description and its input(byte-code) 
as the Turing Machine runs for its input(native code)-portable yet slower. 
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6 Conclusion and future work 


In this thesis, a Turing Machine Simulator was built to serve a visual educa- 
tional aid for computability theory teaching and learning. Also a Universal 
Turing Machine was created to present the core idea about how a Turing Ma- 
chine can simulate another Turing Machine. It shows how a computer and 
algorithm work in the aspect of the computation model. Also, it uses the 
difference in computing performance between Java and C + + as an exam- 
ple, explains why a compiling programming language is generally faster than 
an interpreting language. Computer science origins from these computation 
models we discussed. Learning computation models is an essential step for 
building up an architecture of knowledge for computer science. Looking at 
computer science with “computing” in mind, not only helps students find 
the solution when they encounter some problem but also builds their muscle 
to seek the ‘solution.’ for creating solutions “Meta-Solution”. This thesis 
presents a simulator for the original Alan Turing's machine to show how a 
single tape Turing Machine works. Multi-tapes Turing Machine simulator 
can be built to show how multi-tapes Turing The machine completes a com- 
puting task. How it is different from a single tape Turing Machine. Also, a 
Non-deterministic Turing Machine is beneficial for the understanding of time 
complexity for an algorithm. Think about one of the most critical questions 
in computer science- P = N P?. NP is a set of questions that are defined by a 
non-deterministic Turing Machine. Presenting how different Turing Machine 
variants yield the same result for the problem in a visual animation manner 
can be very helpful for students to gain an understanding of why these mod- 
els are equivalent. Turing Machine is a milestone of computability theory, 
but now all of it. A visual tool for deterministic finite automata(DFA), a 
Regular Expression — DFA converter, a Lambda interpreter, and Lambda — 
Turing Machine converter, all have a significant meaning for a computability 
theory class. 
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